home *** CD-ROM | disk | FTP | other *** search
/ SGI Developer Toolbox 6.1 / SGI Developer Toolbox 6.1 - Disc 4.iso / lib / mathlib / libblas / src_original / sswap.f < prev    next >
Encoding:
Text File  |  1994-08-02  |  1.6 KB  |  74 lines

  1.       SUBROUTINE SSWAP( N, SX, INCX, SY, INCY )
  2. *
  3. *     interchanges two vectors.
  4. *     uses unrolled loops for increments equal to 1.
  5. *     jack dongarra, linpack, 3/11/78.
  6. *
  7. *     .. Scalar Arguments ..
  8.       INTEGER           INCX, INCY, N
  9. *     ..
  10. *     .. Array Arguments ..
  11.       REAL              SX( 1 ), SY( 1 )
  12. *     ..
  13. *     .. Local Scalars ..
  14.       INTEGER           I, IX, IY, M, MP1
  15.       REAL              STEMP
  16. *     ..
  17. *     .. Intrinsic Functions ..
  18.       INTRINSIC         MOD
  19. *     ..
  20. *     .. Executable Statements ..
  21. *
  22.       IF( N.LE.0 )
  23.      $   RETURN
  24.       IF( INCX.EQ.1 .AND. INCY.EQ.1 )
  25.      $   GO TO 20
  26. *
  27. *        code for unequal increments or equal increments
  28. *          not equal to 1
  29. *
  30.       IX = 1
  31.       IY = 1
  32.       IF( INCX.LT.0 )
  33.      $   IX = ( -N+1 )*INCX + 1
  34.       IF( INCY.LT.0 )
  35.      $   IY = ( -N+1 )*INCY + 1
  36.       DO 10 I = 1, N
  37.          STEMP = SX( IX )
  38.          SX( IX ) = SY( IY )
  39.          SY( IY ) = STEMP
  40.          IX = IX + INCX
  41.          IY = IY + INCY
  42.    10 CONTINUE
  43.       RETURN
  44. *
  45. *        code for both increments equal to 1
  46. *
  47. *
  48. *        clean-up loop
  49. *
  50.    20 M = MOD( N, 3 )
  51.       IF( M.EQ.0 )
  52.      $   GO TO 40
  53.       DO 30 I = 1, M
  54.          STEMP = SX( I )
  55.          SX( I ) = SY( I )
  56.          SY( I ) = STEMP
  57.    30 CONTINUE
  58.       IF( N.LT.3 )
  59.      $   RETURN
  60.    40 MP1 = M + 1
  61.       DO 50 I = MP1, N, 3
  62.          STEMP = SX( I )
  63.          SX( I ) = SY( I )
  64.          SY( I ) = STEMP
  65.          STEMP = SX( I+1 )
  66.          SX( I+1 ) = SY( I+1 )
  67.          SY( I+1 ) = STEMP
  68.          STEMP = SX( I+2 )
  69.          SX( I+2 ) = SY( I+2 )
  70.          SY( I+2 ) = STEMP
  71.    50 CONTINUE
  72.       RETURN
  73.       END
  74.